package 双指针;

/**
 * @author admin
 * @version 1.0.0
 * @ClassName 最接近的三数之和.java
 * @Description TODO
 * @createTime 2020年10月15日 21:52:00
 * 给定一个包括 n 个整数的数组 nums 和 一个目标值 target。找出 nums 中的三个整数，使得它们的和与 target 最接近。返回这三个数的和。假定每组输入只存在唯一答案。
 *
 *  
 *
 * 示例：
 *
 * 输入：nums = [-1,2,1,-4], target = 1
 * 输出：2
 * 解释：与 target 最接近的和是 2 (-1 + 2 + 1 = 2) 。
 *
 */
public class 最接近的三数之和 {
//    class Solution {
//        public int threeSumClosest(int[] nums, int target) {
//            Arrays.sort(nums);
//            int ans = nums[0] + nums[1] + nums[2];
//            for(int i=0;i<nums.length;i++) {
//                int start = i+1, end = nums.length - 1;
//                while(start < end) {
//                    int sum = nums[start] + nums[end] + nums[i];
//                    if(Math.abs(target - sum) < Math.abs(target - ans))
//                        ans = sum;
//                    if(sum > target)
//                        end--;
//                    else if(sum < target)
//                        start++;
//                    else
//                        return ans;
//                }
//            }
//            return ans;
//        }
//    }

}
